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(54) Self-arbitrating crossbar switch 



(57) A self-arbitrating and self-routing ATM (Asyn- 
chronous Transfer Mode) switch has a switching fabric 
(10) consisting of rows (15) and columns (16) of logic 
groups (18). The rows (15) of logic groups have ad- 
dressing logic for routing data packets received at input 
ports (6) to the columns (16) of logic groups. Arbitration 
logic in each of the columns (16) of logic groups route 
data packets received from the addressing logic to their 
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specified output ports (8). The arbitration logic forming 
each column (16) of logic groups resolves conflicts be- 
tween data packets contending for an identical output 
port (8). Additional logic in each column (16) of logic 
groups signals input ports (6) when data packets are 
successfully received by their specified output ports (8) . 
Data packets which lose arbitration during a switch cycle 
are assigned a higher priority and retransmitted to the 
switching fabric (10) during the next switch cycle. 
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Description 

The present invention relates generally to high 
speed communication networks, and more particularly, 
to a self-arbitrating crossbar switch suitable for use as 
a switching fabric in an ATM (Asynchronous Transfer 
Mode) switch. 

The ATM (Asynchronous Transfer Mode) protocol 
is an example of a packet switched network protocol that 
supports a plurality of communications services such as 
voice, video, and data. Information is transmitted over 
a network of ATM switches using fixed-sized data pack- 
ets called cells. Routing information that is used to direct 
a data packet to its destination is contained in the header 
of the data packet. The data packet is examined at call 
setup time to determine a fixed route through the net- 
work of ATM switches. Depending on the particular fixed 
route defined, a data packet may travel through a series 
of cascaded switches before arriving at Its destination. 

A data packet received at an input port of a switch 
is routed by a switching fabric to an output port of the 
switch, with this output port being defined by the data 
packet's routing information. The switching fabric of a 
switch may have the property of being "non-blocking" 
and/or "self-routing", as well as other features that are 
not especially relevant to the following discussion. A 
non-blocking switching fabric is capable of generating 
all possible permutations of the inputs to the outputs. A 
self-routing switching fabric uses destination informa- 
tion that is included in a data packet to determine the 
route through the switching fabric. 

Switching fabrics that are "non-blocking" tend to be 
difficult to scale to a large number of input ports and out- 
put ports. For example, crossbar switches have switch- 
ing fabrics that directly connect each input port to each 
output port and are therefore non-blocking. However, 
these switches have the disadvantage of having the ar- 
ea of the cross bar fabric grow by the square of the 
number of ports. In contrast, the general architecture of 
a Batcher-Banyan fabric which includes a Batcher sort- 
ing network and a Banyan routing network, asymptoti- 
cally requires less circuitry as the number of input ports 
and output ports of the switching fabric increases than 
the aforementioned cross bar switch architecture. How- 
ever, this reduction in circuitry results in the Batcher- 
Banyan switching fabric being more complicated and in- 
creases the difficulty in fault isolation relative to a cross- 
bar fabric. 

In addition to a switching fabric, a switch typically 
includes an arbiter for providing organized access to the 
output ports of the switching fabric. The arbiter's func- 
tion in a switching fabric that routes no more than one 
data packet to each output port per switch cycle, is to 
resolve contention among output ports when more than 
one input port attempts to access the same output port 
during a single switch cycle. Contention for output ports 
is known to produce head of line blocking in input 
queued switches and to reduce throughput. It is well 



known that output port contention can be reduced by 
adding a speedup factor of "k" which enables each out- 
put port to receive up to "k" data packets per switch cy- 
cle. In an ATM switch with a switching fabric having a 
s speedup factor of "k", however, the arbiter must still re- 
solve contention among input ports when the number of 
data packets destined to any one output port exceeds 
V. 

An example of a distributed arbiter that resolves 
10 conflicts between input ports contending for identical 
output ports is a reservation ring, an example of which 
is disclosed in U.S. Patent No. 5,511 ,070. A reservation 
ring can be implemented using a linear systolic array of 
evaluators where each evaluator performs arbitration 
15 functions with its immediate neighbour. Each evaluator 
on the ring arbitrates for a specified input port during an 
arbitration cycle. Such a distributed arbiter advanta- 
geously utilizes the time necessary to send the fifty- 
three bytes of an ATM cell through the switching fabric 
20 to identify which cells to route during the next switch cy- 
cle. Even though distributed arbiters such as the reser- 
vation ring scale linearly, they do not scale well as the 
number of input ports and the bandwidth of the switching 
fabric increases because any given reservation request 
25 must be shifted through each evaluator on the reserva- 
tion ring in one cell time. 

According to this invention a switch for routing data 
packets with destination addressing information and pri- 
ority information, comprises 

30 

a plurality of input ports for receiving data packets 
from input sources and a plurality of output ports for 
transmitting data packets to output destinations; 
and 

35 

a network of logic groups for routing data packets 
received at the plurality of input ports to the plurality 
of output ports; said network of logic groups forming 
intersecting rows of logic groups and columns of 
40 logic groups; wherein the rows of logic groups in- 
clude logic for selecting output columns to receive 
data packets, and the columns of logic groups in- 
clude logic for ordering data packets according to 
their priority information to determine which data 
45 packets received at said input ports to present to 
said output ports. 

Particular embodiments of this invention will now be 
described with reference to the accompanying draw- 
so ings; wherein the same reference numerals have been 
applied to like parts and in which:- 

Figure 1 illustrates the organization of the switching 
fabric of a switch incorporating the present inven- 
ts tion; 

Figure 2 illustrates the general organization of the 
logic groups identified by reference number 19 in 
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(54) Self-arbitrating crossbar switch 

(57) A self-arbitrating and self-routing ATM (Asyn- 
chronous Transfer Mode) switch has a switching fabric 
(10) consisting of rows (15) and columns (16) of logic 
groups (18). The rows (15) of logic groups have ad- 
dressing logic for routing data packets received at input 
ports (6) to the columns (1 6) of logic groups. Arbitration 
logic in each of the columns (16) of logic groups route 
data packets received from the addressing logic to their 



specified output ports (8). The arbitration logic forming 
each column (16) of logic groups resolves conflicts be- 
tween data packets contending for an identical output 
port (8). Additional logic in each column (16) of logic 
groups signals input ports (6) when data packets are 
successfully received by their specified output ports (8) . 
Data packets which lose arbitration during a switch cycle 
are assigned a higher priority and retransmitted to the 
switching labric (10) during the next switch cycle. 
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Figure 1; 

Figure 3 is a flow diagram that sets forth three phas- 
es of operation of the switching fabric: 

Figure 4 illustrates a block diagram of connections 
between logic blocks for performing the addressing 
phase of the switching fabric; 

Figure 5 defines different states of a state machine 
operating in each logic block when the switching 
fabric is in the addressing phase of operation; 

Figure 6 illustrates a block diagram of the connec- 
tions between logic blocks for performing the arbi- 
tration phase of the switching fabric; 

Figure 7 illustrates a single logic block and its con- 
nections that operate during the arbitration phase; 

Figure 8 illustrate combinatorial logic and a finite 
state machine in a logic block of the switching fabric 
for performing the arbitration phase; 

Figure 9 illustrates a state transition diagram for the 
finite state machine shown in Figure 8; 

Figure 10 illustrates virtual connections created in 
a logic block for each of the three states of the finite 
state machine shown in Figure 9; 

Figures 11 and 12 illustrate examples of combina- 
tions of logic blocks in a logic group that route data 
packets horizontally and vertically during an arbitra- 
tion phase; 

Figure 1 3 illustrates a block diagram of connections 
between logic blocks of the switching fabric for per- 
forming the acknowledgment phase of the switch- 
ing fabric; 

Figure 1 4 illustrates a single logic block and its con- 
nections for performing the acknowledgment phase 
of the switching fabric; 

Figure 15 illustrates combinatorial logic and finite 
state machine that operate in a logic block during 
the acknowledgment phase of a switching cycle; 
and, 

Figures 16 and 17 illustrate examples of two differ- 
ent logic groups after completing an arbitration 
phase; 

A. System Overview 

Referring now to the drawings where the showings 
are for the purpose of describing an embodiment of the 



invention and not for limiting same, the Figures illustrate 
a self-routing, self-arbitrating ATM switch 5 incorporat- 
ing the present invention. The switch 5 is adapted to 
route fixed sized data packets, called "cells-, from input 

5 ports 6 to output ports 8 through a cross-bar switching 
fabric 10. Before an ATM cell enters the switching fabric 
10, an input source (not shown) causes a fixed route, 
known as a "virtual circuit", to be determined for trans- 
ferring the cell from its source to its destination. One way 

10 for a cell to be routed through a network of switches is 
with a hop-by-hop addressing scheme. According to this 
addressing scheme once a cell is received at an input 
port of switch 5, a virtual circuit identifier (VCl) from the 
cell's header is used to identify, in a VCl table, a replace- 

15 ment VCl and an output port address. The output port 
address identified from the VCl table for a cell specifies 
which output port 8 to route the cell through the switch- 
ing fabric 10. 

It will be appreciated by those skilled in the art that 

20 the switch 5 embodying the present invention is not lim- 
ited to operating in an ATM network but instead can be 
modified to operate in most packet switched networks. 
It will also be appreciated that the present invention 
does not require the switch 5 to route fixed-sized data 

25 packets (i.e., ATM cells) but instead can route data 
packets with a varying size. 

Figure 1 illustrates the organization of the switching 
fabric 10 of the switch 5. The switching fabric 10 is or- 
ganized in an "N x NT array of input rows 15 and output 

30 column groups 16, where "NT is an integer. Each of the 
N input rows 15 is coupled to an input port 6 (i.e. I[1] .. 
I [N]), and each of the N output column groups 1 6 is cou- 
pled to an output port 8 (i.e. 0[1] .. 0[N]). At the inter- 
section of each input row 15 and output column group 

35 1 6 is a logic group 1 8. Each logic group 1 8 in the switch- 
ing fabric 10 comprises addressing logic, arbitration log- 
ic (or routing logic), and acknowledgment logic. In gen- 
eral, the addressing logic identifies whether a data pack- 
et is destined to the output port to which its output col- 

40 umn group is coupled; the arbitration logic resolves con- 
flicts between input ports contending for identical output 
ports during a switch cycle while routing data packets to 
their specified output ports; and the acknowledgment 
logic provides a signal to an input port indicating whether 

45 jts data packet was successfully routed to its specified 
output port(s). A switch cycle is defined herein to have 
sufficient bit cycles to deliver a data packet through the 
switching fabric from an input port 6 to an output port 8. 
Figure 2 illustrates the general organization of the 

50 logic groups 1 8 identified by reference number 1 9 in Fig- 
ure 1 . Specifically, each logic group 18 consists of a set 
of logic blocks B[i,j] (1), B[i,j] (2), B[i,j] (3). and B[i,j] (4). 
Each logic block 22 in the switching fabric 1 0 is address- 
able by the indices Y, "j", and "m", where V identifies 

55 an input port 6 coupled to an input column 15, "j" iden- 
tifies an output port 8 coupled to an output column group 
16, and B m M identifies an output column 20 of an output 
column group (i.e. B[i,j] (m)). Input ports 6 include buff- 
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ers for storing data packets received from an input 
source until a confirmation is received that the data 
packets have been successfully routed to their specified 
output ports. 

It is well known that head of queue blocking at input 
ports 6 can cause a gross degradation in the overall 
throughput of a switch. U.S. Patent No. 5,305,311 dis- 
closes the notion of speeding up each output port by a 
factor of "k" each switch cycle to minimize head of queue 
blocking. This "k" speedup per output port increases 
throughput from approximately 58% for k=1 {i.e. a 
switch with only input queuing) to approximately 89% 
for k=2 and nearly 1 00% for k=4 and above. The present 
invention achieves a speed up by defining each output 
column group 16 with "k" output columns 20, as illustrat- 
ed in Figures 1 and 2. That is, each output port 8 is cou- 
pled to u k n output columns 20, and is, therefore, able to 
receive up to "k" data packets each switch cycle. Spe- 
cifically, each output port 8 is coupled to "k" output col- 
umns 20 that are defined herein as 0[j] (1), 0[j] (2), ... 
0[j] (k) . Accordingly, a switching fabric with "k" output 
columns has "k" logic blocks 22 (i.e. B[i : j] (1) ... B[i,j] 
(m) ... B[ij] (k)) per logic group 18. In addition, output 
ports 8 include buffers for queuing data packets that are 
simultaneously received over output columns 20 at an 
output port during a switch cycle. The buffers insure that 
when more than one data packet is received during a 
switch cycle at a single output port, some of these data 
packets can be stored until they are sent over an adjoin- 
ing link of the network (not shown). 

Figure 3 is a flow diagram that sets forth three phas- 
es of operation of the switching fabric 1 0. Initially at step 
100, the switching fabric 10 operates in an addressing 
phase during which specified output addresses of data 
packets buffered at input ports 6 are matched with ad- 
dresses of output column groups 16. At step 102, the 
switching fabric operates in a routing or arbitration 
phase. During the arbitration phase data packets with 
addresses that match an output column group 16 arbi- 
trate for the output port 8 to which the output column 
group is coupled. At step 104, the switching fabric 10 
operates in an acknowledgment phase during which in- 
put ports receive a signal indicating whether a data 
packet was successfully transmitted to a specified out- 
put port(s). Those data packets which are not success- 
fully routed to their specified output port(s) are resub- 
mitted to the switching fabric 10 during the next switch 
cycle. Embodiments detailing each of the three phases 
of operation are discussed in turn below. 

B. Addressing Logic 

Figure 4 illustrates a block diagram of connections 
between logic blocks 22 that include addressing logic 
for performing the addressing phase of the switching 
fabric 10. At the start of a switch cycle data packets re- 
ceived from input sources and stored at input ports 6 
are synchronously presented to the switching fabric 1 0. 



As set forth above, the routing information which is set 
forth in a data packet's header is used to identify in a 
VCI table a specified output port(s) 8 of the switch 5 to 
which the data packet is to be routed. Data packets may 

5 be routed to one or more output ports 8 depending on 
whether the data packet is a multicast or a unicast data 
packet. Modifications to the switch 5 that are necessary 
for supporting multicast data packets are described be- 
low in Section F. 

10 During the addressing phase, output port address 
of each data packet sent serially on the input lines 24 
are matched against the address (e.g. A[j]) of each out- 
put column group 1 6 sent vertically on address lines 26. 
More specifically, during the addressing phase each in- 

75 put port 6 serially transmits an output port address vec- 
tor, a priority vector, and a data packet such as an ATM 
cell over input lines 24. Each input line 24 in the switch- 
ing fabric is coupled to an input port and a logic group 
18 from each output column group 16 to form an input 

20 row 15. Input ports 6 with no buffered data packets at 
the start of a switch cycle transmit idle packets with an 
output port address vector that does not match any of 
the addresses of the output ports 8 of switch 5. Simul- 
taneously while each input port 6 transmits an address 

25 vector along input lines 24, each output ports 8 serially 
transmits an address vector with its address along an 
address line 26 (e.g. A[j]). Each address line 26 couples 
a logic group 18 in each input row 15 with an output port 
8. While simultaneously receiving an address vector 

30 over an input line 24 and an address line 26, each logic 
group 18 determines whether the output port addresses 
are equal. In an alternate embodiment with no address 
lines 26, this determination is made by matching an ad- 
dress vector received over input lines 24 with an ad- 

35 dress vector that is embedded in the logic group 18. The 
embedded address vector in each logic group 18 corre- 
sponds to the address of the output port to which it is 
coupled. 

Figure 5 defines different states of a finite state ma- 

40 chine operating in each logic block 22 when the switch- 
ing fabric 10 is in the addressing phase of operation. As 
Figure 5 illustrates, there are two states (i.e., the "MAY- 
BE" state and the "NO" state) in which a logic block 22 
can enter after being initialized at the start of a new 

45 switch cycle to the "MAYBE" state. After initialization, 
the "k" logic blocks 22 in a logic group 18 do not transi- 
tion from the "MAYBE" state when the address bits 
transmitted horizontally on input lines 24 match the ad- 
dress bits transmitted on address lines 26 (i.e. I[i] = A 

so [j]). However, the M k" logic blocks 22 in a logic group 18 
transitions to the "NO" state when the address bits are 
no longer equal (i.e. I[i] * A[j]). A more detailed descrip- 
tion of a finite state machine for implementing the ad- 
dressing phase of the switching fabric is disclosed in U. 

ss S. Patent No. 5,602,844. 

For example, assume input port l[i] transmitted the 
binary address vector "1010" and the address line A[j] 
transmitted binary address vector "1011° during the ad- 
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dressing phase. Since the address vectors in this exam- 
ple have four bits, the length of the address phase takes 
four bit cycles to complete. In operation, the input port I 
[i] and the address line A[j] transmit an address bit each 
bit cycle starting with the most significant bit to a logic 
block 22 coupled thereto. In this example, the finite state 
machine in the logic block 22 would remain in the "MAY- 
BE" state until the least significant bit is received at 
which time the state machine transitions to the "NO" 
state. However, if the addresses were equal the state 
machine would have remained in the "MAYBE" state. 

C. Arbitration Logic 

As set forth above, each input port serially transmits 
during a switch cycle an output port address vector, a 
priority vector, and a data packet. After the addressing 
phase of a switch cycle, an output port address vector 
from each input port has been transmitted to each logic 
group 18. During the arbitration phase of the switch cy- 
cle, a priority vector is received and evaluated by each 
logic group. 

A value indicating the priority of a data packet is 
designated at the start of a switch cycle and inserted in 
a priority vector that is transmitted following the address 
vector. An initial priority value is specified in the priority 
vector from a priority metric set forth in the header of the 
data packet. For example, ATM cell headers include a 
priority metric that indicates different classes of traffic. 
These different classes of traffic distinguish, for exam- 
ple, between real time traffic and best effort traffic. If a 
data packet is unsuccessfully routed through the switch- 
ing fabric during a switch cycle, the priority value in the 
priority vector is increased or otherwise modified for that 
data packet during the next switch cycle before being 
resubmitted to the switching network. 

Figure 6 illustrates connections between logic 
blocks 22 that include arbitration logic for performing the 
arbitration phase of the switching fabric 1 0. Data pack- 
ets that are successfully addressed to an output column 
group 16 during the addressing phase are routed verti- 
cally during the arbitration phase along an output col- 
umn 20 unless a data packet with a greater priority is 
encountered. When two priority vectors of two data 
packets meet at a logic block 22, the priority vector of 
the two data packets with the greater priority is routed 
vertically along an output column 20 while the data pack- 
et with the lower priority is routed horizontally within a 
logic group 18. This vertical and horizontal routing sorts 
data packets with identical output port address accord- 
ing to their designated priority. 

Figure 7 illustrates a single logic block 22 and its 
connections that operate during the arbitration phase. 
A logic block 22 (i.e., B[i,j] (m)) has an input horizontal 
connection 28 (i.e. , H[i, j] (m«1 )) and an output horizontal 
connection 30 (i.e., H[i,j] (m)). The logic blocks 22 in a 
logic group 18 are connected horizontally in series to 
form part of an input row 15 as shown in Figure 6. How- 



ever, these horizontal connections 28 and 30 between 
logic blocks 22 do not extend beyond each output col- 
umn group 16. Specifically, the leftmost input horizontal 
connection 28 within an input row 15 (e.g., H[i,j] (0)) is 

5 coupled to input line 24 and the rightmost output hori- 
zontal connection 30 within an input row 15 (e.g., Hfi,j] 
(4)) terminates. In addition, the logic block 22 in each 
output column 20 are connected in series between logic 
groups 18 by an input vertical connection 32 (i.e., V[i,j] 

io (m-1)) and an output vertical connection 34 (i.e., V[i,j] 
(m)). These vertically connected logic groups form an 
output column 20 as shown in Figure 6. 

With reference again to Figure 6, during the arbitra- 
tion phase contention is resolved among output ports 8 

15 when more than one input port 6 attempts to route data 
packets to an identical output port during a single switch 
cycle. Each output column group 16 serves as an inde- 
pendent arbiter for the output port coupled thereto. In 
other words, each output column group 16 individually 

20 arbitrates among data packets destined for a single out- 
put port during the arbitration phase. In sum, the ad- 
dressing phase and the arbitration phase sequentially 
sort data packets according to output port address and 
data packet priority, respectively, to identify those data 

25 packets which are routed to the output ports during a 
switch cycle. 

More specifically, a data packet transmitted from in- 
put port with an output port address that matches the 
address of the output column group 0[j] during the ad- 

30 dressing phase is initially routed during the arbitration 
phase to logic block B[i,j] (1 ). At each logic block 22 in 
an output column 20, a determination is made whether 
to route the data packet horizontally or vertically. If a da- 
ta packet is routed or shifted horizontally more than "k" 

35 logic blocks 22, then the data packet is not successfully 
routed to its specified output port because the output 
horizontal connection 30 of the "k"th logic block 22 in a 
logic group 18 terminates (e.g. H[i,j](4)). That is, a data 
packet which is routed horizontally from logic block B[i, 

40 j] (4) is dropped during the current switch cycle and re- 
transmitted during the next switch cycle. As set forth 
above, the priority of a data packet that is unsuccessfully 
routed during the current switch cycle is increased dur- 
ing the next switch cycle in order to improve the likeli- 

45 hood that the data packet reaches its specified output 
port. 

Figure 8 illustrates combinatorial logic 21 and a fi- 
nite state machine 23 that operate in each logic block 
22 of the switching fabric 10 for performing the arbitra- 

50 tion phase. Figure 9 illustrates a state transition diagram 
for the finite state machine 23 shown in Figure 8. As 
shown in Figure 9, the combinatorial logic 21 operates 
in one of three states depending on the current state of 
the finite state machine 23. The three states of the finite 

55 state machine 23 are "NO", "MAYBE", and "YES". The 
finite state machine is initialized to the "MAYBE" state. 
The "MAYBE" state exists because it may not always be 
possible for a logic block 22 to immediately determine 
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which data packet has a higher priority since the priority 
vector of a data packet is sent serially along input lines 
24. Thus, a logic block 22 will remain in the "MAYBE" 
state as long as the priority bits received trom the hori- 
zontal and vertical connections are identical. When the 
finite state machine 23 is in the "NO" or "YES" state, the 
priority of a data packet routed vertically along input ver- 
tical connection 32 (i.e. V[i,j] (m-1)) and horizontally 
along input horizontal connection 28 (i.e. H[i,j] (m-1)) 
has been determined. 

In the intermediate "MAYBE" state, when a priority 
determination cannot be made, the combinatorial logic 
21 shown in Figure 8 immediately arbitrates and routes 
the current priority bit before the next transition of the 
finite state machine 23. If at the end of the arbitration 
phase a state machine continues to be In the "MAYBE" 
state, then the data packet routed vertically has an iden- 
tical priority as the data packet routed horizontally. Such 
ties in priority between data packets are broken in favour 
of horizontally routed cells by transitioning the state ma- 
chine from the "MAYBE" state to the "YES" state after 
completely receiving the data packet priority vectors. Al- 
ternatively, it will be understood by those skilled in the 
art that priority ties could also be broken in favour of ver- 
tically routed cells. 

In summary, Figure 10 illustrates virtual connec- 
tions created in a logic block 22 for each of the three 
states of the finite state machine 23 (i.e. MAYBE, NO, 
and YES). In the "MAYBE" state when no determination 
of priority has been made, bits from vertically routed and 
horizontally routed data packets are directed both hori- 
zontally and vertically since they are identical. Once a 
determination of priority is made between a horizontally 
routed data packet and a vertically routed data packet, 
the state machine 23 transitions to a "NO" state or a 
"YES W state. In the "NO" state, the combinatorial logic 
21 shown in Figure 8 defines a virtual connection be- 
tween the input horizontal connection 28 and the output 
horizontal connection 30, and a virtual connection be- 
tween the input vertical connection 32 and the output 
vertical connection 34. In the 'YES" state, the combina- 
torial logic 21 defines a virtual connection between the 
input horizontal connection 28 and the output vertical 
connection 34, and a virtual connection between the in- 
put vertical connection 32 and the output horizontal con- 
nection 30. Figures 11 and 1 2 illustrate examples of dif- 
ferent logic blocks 22 that are combined in a logic group 
18 to route data packets horizontally and vertically dur- 
ing the arbitration phase. 

D. Acknowledgment Logic 

Figure 1 3 illustrates a block diagram of the connec- 
tions between logic blocks 22 of the switching fabric 10 
that operate during the acknowledgment phase of the 
switching fabric. After the end of the arbitration phase, 
an input port receives an acknowledgment signal that 
indicates the data packet was or was not successfully 



routed to a specified output port of the switch. That is, 
during the acknowledgment phase, an input port 6 re- 
ceives a signal over acknowledgment line 38 indicating 
whether a data packet was successfully routed through 

5 the switching fabric 10 to its specified output port. The 
acknowledgment phase begins as soon as data packets 
received by the output column groups at the start of the 
arbitration phase have propagated to the input row hav- 
ing the largest index value (N), as shown in Figure 1. 

10 Thus, the acknowledgment phase operates while the ar- 
bitration phase completes the routing of data from data 
packets that successfully gained access to an output 
port during the current switch cycle. 

Figure 14 illustrates a single logic block 22 and its 

is connections that operate during the acknowledgment 
phase of the switching fabric 10. Logic blocks 22 are 
coupled to each other in an output column group by ver- 
tical acknowledgment connections 36. In addition, each 
input port 6 is coupled to the logic blocks 22 in its input 

20 row 15 by horizontal acknowledgment line 38. For ex- 
ample, the input port l[i] receives an acknowledgment 
signal S[i] over acknowledgment line 38 equal to V 
when the data packet is properly routed to its destination 
output port. In contrast, the input port l[i] receives an 

2S acknowledgment signal S[i] that is equal to "0" when the 
data packet is unsuccessfully routed to its destination 
output port. Data packets which are unsuccessfully rout- 
ed during a current switch cycle are resubmitted to the 
switching fabric 1 0 during the next switch cycle. 

30 Figure 1 5 illustrates combinatorial logic 35 and finite 
state machine 23 that operate in a logic block 22 during 
the acknowledgment phase of a switching cycle. At the 
start of the acknowledgment phase, vertical signals "U" 
to the logic blocks in input row l[N] (i.e. the input row 

35 having the largest index value (N)) are initialized to °0". 
(Input row l[N] is the input row immediately coupled to 
output ports 8 of the switch 5 as shown in Figure 1 .) The 
combinatorial logic in each logic block 22 of the switch- 
ing fabric 10 generates acknowledgment signals "S" for 

40 the "k" highest priority data packets that are successfully 
routed to their destination output ports during a switch 
cycle. In addition, the combinatorial logic insures that 
the vertical signals "U" are propagated to succeeding 
input rows 15 (i.e. I[N], l[N-1J, l[N-2], ...). In operation, 

45 the signals remain "0" until they are converted into an 
acknowledgment signal S[i]. In other words, the horizon- 
tal acknowledgment signals "S" of an input port remains 
"0" until a logic group 18 in its corresponding input row 
15 has a vertical signal "U" that transitions to "1". Fur- 

50 thermore, vertical °U=0" signals are converted into hor- 
izontal acknowledgment signals in right to left order, so 
that the "U" signals are always monotonic within a logic 
group. 

Besides acknowledging the delivery of data packets 
55 to output ports 8, the acknowledgment logic can also 
serve as a form of output port flow control. Providing flow 
control, enables each output port 8 to independently lim- 
it the number of data packets that it receives during a 
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switch cycle. For example, an output port 8 can use flow 
control to limit the number of data packets it receives 
during a switch cycle when its output port buffers are 
full. To use the acknowledgment logic as flow control, 
an output port initializes some or ail of the "k" vertical 
signals "IT of the logic blocks in input row l[N] to "1" 
instead of "0", depending on the number of data packets 
the output port would like to accept during a switch cycle. 
The number of vertical signals "U" initialized to "0" of the 
logic block in input row l[N] dictates how many data 
packets an output port will receive during a switch cycle. 
When an output port accepts less than B k" data packets, 
the "k" vertical signals "IT in input row l[N] are initialized 
in a monotonic ordering of zeros to ones from left to right. 
This monotonic ordering insures that those data packets 
with the highest priority are received first. 

As described above, the finite state machine 23 in 
each logic block 22 of an output column group 16 is ei- 
ther in the "YES" state or the "NO" state at the end of 
the arbitration phase. As shown in the two examples in 
Figures 11 and 12, the states of the logic blocks 22 dic- 
tate whether data packets that are routed in a column 
group are routed horizontally or vertically. Recall that da- 
ta packets with a higher priority are routed vertically, and 
that data packets that are routed horizontally more than 
"k" logic blocks 22 during a switch cycle must be resub- 
mitted during the next switch cycle. 

In operation during the acknowledgment phase, the 
combinatorial logic 35 locates the rightmost vertical sig- 
nal a U" in an output column 20 of a logic group 18 with 
a value equal to "0". Subsequently, if the state of the 
logic block is in the "YES" state, the combinatorial logic 
35 changes the vertical signal "IT in that input row to a 
value equal to T and the acknowledgment signal °S U 
in that output column 20 to a value equal to "1". The 
combinatorial logic 35 of a logic block does not modify 
the vertical signal "U" or raise a horizontal acknowledg- 
ment signal M S" that is equal to "1 " when a logic block is 
in the "NO" state. In effect, the combinatorial logic 35 
insures that vertical signals "U" with a value that is equal 
to "0" in a logic group 18 are delivered to higher priority 
rows of the switching fabric 10. 

In order for the arbitration phase to operate correctly 
with the combinatorial logic 35 shown in Figure 1 5, the 
arbitration phase logic sorts contending data packets so 
that the states of logic blocks 22 in a logic group 1 8 de- 
fine a monotonic sequence of "YES" and "NO" states 
(e.g. NO, YES, YES : YES - see Figures 11). Monotonic 
ordering insures that there are as many logic blocks in 
the "NO" state at the beginning of the sequence as there 
are data packets of higher priority with lower input indi- 
ces destined to the same output port. As set forth above, 
logic blocks in a sequence of "YES" and "NO" states are 
in the "YES" state when cells of lower priority with lower 
input indices are displaced by the data packet in the cur- 
rent input row. The "YES" and "NO" states are monot- 
onically ordered because all packets entering a logic 
group are sorted by priority. Because both the "YES" 



12 

and "NO" states of a logic group 18, and the "U" states 
are ordered monotonically in the logic group 18, it is 
easy to compare the number of available output ports 
with the number of higher priority input ports with lower 

5 input indices. 

Figures 16 and 17 illustrate two different logic 
groups which have completed the arbitration phase. Fig- 
ures 16 and 17 correspond to the logic groups shown in 
Figures 11 and 12, respectively, which have completed 

10 the arbitration phase. As set forth above initially, the 
rightmost input vertical signaPLr which has a zero value 
is located in the logic groups 18. This rightmost "LT sig- 
nal is indicated by reference number 46 in Figures 16 
and 17. Figure 16 illustrates an example where a data 

15 packet from an input port coupled to acknowledgment 
line S[i] was successfully routed. Because the logic 
block indicated by reference number 48 is in the "YES" 
state, the horizontal acknowledgment signal "S" and the 
vertical signal "U" are modified from a value equal to "0" 

20 to a value equal to "1 ". In contrast, Figure 17 illustrates 
an example where a data packet from input port coupled 
to acknowledgment line S[i] was unsuccessfully routed. 
Because the logic block with the rightmost vertical signal 
"U" (indicated by reference number 46) that is zero is 

2S input to a logic block (indicated by reference number 48) 
which is in the 'NO" state, neither the horizontal ac- 
knowledgment signal "S" or the vertical signal "IT are 
modified from their original "0" value. 



In summary, the architecture of the switch incorpo- 
rating the present invention can be advantageously 
used to develop large scale switches. This advantage 
can be realized because the switching fabric is regularly 
repeating. A regularly repeating fabric is ideal for custom 
implementations because the switch has the advantage 
of being readily scalable to a varying number of ports. 
Furthermore, the switching fabric disclosed herein has 
the additional advantage that most connections be- 
tween logic blocks 22 are local (e.g., input vertical con- 
nection 32, output vertical connection 34, input horizon- 
tal connection 28, and output horizontal connection 30). 
This advantage facilitates the tiling of logic blocks on the 
surface of a chip because an extensive number of non- 
local connections (e.g. input line 24) are not required 
between logic blocks. 

It will be understood by those skilled in the art that 
the present invention does not require that data packets 
are serially transmitted through the switching fabric; in- 
stead, the switching fabric can be modified to incorpo- 
rate different degrees of parallelism. For example, input 
line 24 shown in Figure 4 can include two lines so that 
addressing and arbitration can be pipelined with data 
transmission. One line is used to send the data for the 
current cell, while the other lines is used to perform ad- 
dressing and arbitration for the next cell. 

In addition, it will be understood by those skilled in 
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the art that defining the input lines with a horizontal ori- 
entation and the output lines with a vertical orientation 
should not impose any physical limitations on the orien- 
tation of the input lines or output lines of the switch. For 
example, input lines could be oriented vertically and the 
output lines could be oriented horizontally. 



Claims 

1. A switch for routing data packets with destination 
addressing information and priority information, 
comprising: 

a plurality of input ports for receiving data pack- 
ets from input sources and a plurality of output 
ports for transmitting data packets to output 
destinations; and 

a network o( logic groups for routing data pack- 
ets received at the plurality of input ports to the 
plurality of output ports; said network of logic 
groups forming intersecting rows of logic 
groups and columns of logic groups; wherein 
the rows of logic groups include logic for select- 
ing output columns to receive data packets, and 
the columns of logic groups include logic for or- 
dering data packets according to their priority 
information to determine which data packets re- 
ceived at said input ports to present to said out- 
put ports. 

2. A switch according to claim 1 , wherein each row of 
logic groups comprises logic for matching destina- 
tion addressing information of a data packet trans- 
mitted from an input port coupled thereto with ad- 
dresses of the plurality of output ports. 

3. A switch according to claim 1 or 2, wherein each 
column of logic groups comprises logic for routing 
up to "k" data packets received from intersecting 
rows of logic groups to an output port coupled there- 
to. 

4. A switch according to claim 3, wherein "k B is equal 
to one. 

5. A switch according to any of the preceding claims, 
wherein the rows and columns of logic groups fur- 
ther comprise logic for identifying data packets suc- 
cessfully routed to said output ports. 

6. A switch according to claim 5, wherein said logic for 
identifying data packets successfully routed to said 
output ports identifies data packets successfully 
routed using the ordering of data packets by the col- 
umns of logic groups. 
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7. A switch according to any one of the preceding 
claims, wherein each column of logic groups com- 
prises 'V columns of logic blocks. 

5 8. A switch according to claim 7, wherein said network 
of logic groups further comprises a sorting element 
for sorting data packets by a predefined priority met- 
ric. * 

10 9. A switch according to claim 7 or 8, wherein said ar- 
bitration logic routes data packets with lower priority 
between columns of logic blocks and data packets 
with higher priority within a column of logic blocks. 

is 10. A switch according to claim 9, wherein a data packet 
routed between "k° columns of logic blocks is resub- 
mitted to said network of logic groups. 
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Determine whether the destination output addresses of data packets 
at the input ports match the address of the output column groups of the switching fabric. 



^102 



Arbitrate between data packets contending for identical output ports while routing the cells 
received at each output column group through the switching fabric. 



Acknowledge receipt at each input port of data packets successfully routed through 
the switching fabric during a switch cycle. 



FIG. 3 
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